## TUTORIAL: QSYS CUSTOM ST COMPONENT

## Goal

Create a custom component in Qsys with an ST Interface.

## **Prerequisites**

- Quartus
- · You must be familiar with Qsys.

## How To Do It

A) With Qsys open, press "new" in the "Component Library" panel to the left. This opens the following dialog:



Add your hdl files and let it analysed. If analysis fails, you should go back to ModelSim and debug your code. Ensure that your interfaces are correct, that you have no unresolved generics and that the code can be synthesized (no test becnh constructions). The figure above shows two files, the "iis2st.vhd" contains the actual code, whereas the iis2st\_rtl.vhd only wraps it and selects the appropriate architecture and sets the value of the generics in iis2st.vhd.

B) Identify the interfaces. The next page lets you assign the design entity ports to well-known interfaces (Avalon-MM / Avalon-ST / clock / conduit) See mnl\_avalon\_spec.pdf Right-click on the interface and select ex "new Avalon Streaming Source" if need such an interface. Re-use this interface for the remaining source signals. Note that the "clk" and "reset\_n" both must use the same clock interface. This way we indicate that they are related.



C) Going to the "Interfaces" page, you should start out by pressing "Remove Interfaces with no Signals" if it is not faded out. The streaming busses will have to have a clock signal associated. Select the clock signal. A reset signal may not be required. You also have to specify the number of bits per symbol. Qsys expects only one symbol per beat, so you'll have to specify the number of bits you expect to transfer in parallel. Not the waveform at the bottom, this should reflect what you want.



- D) In the next page you may specify author, group and a lot more. Adding a group, say "ASE" will put your custom component in an ASE folder in the component library. Press Finish
- E) You are now able to add your custom component to your project. You can right-click and filter the interfaces shown in the SOC overview. The new component will have source and sink busses that you can connect to other ST-bus components (with similar formatting) or use adapters from the component library adapt the ST-bus format

